// pages/search/search.js
import {
  setWatcher,
  request
} from '../../utils/util'
Page({
  // 确定搜索
  handleSearch(e) {
    // 保存搜索记录
    this.saveSearchHistory(e.detail)
    // 搜索
    this.getSearchList(e.detail)
  },
  // 保存搜索记录
  saveSearchHistory(value) {
    const {
      searchHistory
    } = this.data;
    searchHistory.unshift(value)
    // 保存  去除重复
    this.setData({
      searchHistory: [...new Set(searchHistory)]
    })
  },
  // 删除搜索记录
  removeSearchHistory(e) {
    const value = e.target.dataset.value;
    const {
      searchHistory
    } = this.data
    this.setData({
      searchHistory: searchHistory.filter(v => v !== value)
    })
  },
  // 清空搜索搜索
  clearSearchHistory() {
    wx.showModal({
      title: '警告',
      content: '确定要清空搜索记录吗？',
      complete: (res) => {
        if (res.cancel) {
          // 取消
        }

        if (res.confirm) {
          // 确定
          this.setData({
            searchHistory: []
          })
        }
      }
    })


  },
  async getSearchList(value) {
    const resp = await request({
      url: 'http://localhost:3000/list',
      data: {
        q: value
      }
    })
    this.setData({
      searchList: resp.data
    })
  },
  /**
   * 页面的初始数据
   */
  data: {
    // 存储搜索的结果
    searchList: [],
    // 存储搜索的历史记录
    searchHistory: wx.getStorageSync('searchHistory') || []
  },
  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    setWatcher(this)
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {},
  watch: {
    searchHistory(searchHistory) {
      wx.setStorageSync('searchHistory', searchHistory)
    }
  },
  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})